package com.zzxx.userManagement.utils;

import java.security.MessageDigest;

/**
 * 写一个MD5算法,运行结果与MySQL的md5()函数相同
 * 将明文密码转成MD5密码
 * 123456 -> e10adc3949ba59abbe56e057f20f883e
 */
public final class Md5Util {
    private Md5Util() {
    }

    /**
     * 将明文密码转成MD5密码
     */
    public static String encodeByMd5(String password) throws Exception {
        // Java中MessageDigest类封装了MD5和SHA算法，今天我们只要MD5算法
        MessageDigest md5 = MessageDigest.getInstance("MD5");
        // 调用MD5算法，即返回16个byte类型的值
        byte[] byteArray = md5.digest(password.getBytes());
        // 注意：MessageDigest只能将String转成byte[]，接下来的事情，由我们程序员来完成
        return byteArrayToHexString(byteArray);
    }

    /**
     * 将byte[]转在16进制字符串
     */
    private static String byteArrayToHexString(byte[] byteArray) {
        StringBuffer sb = new StringBuffer();
        // 遍历
        for (byte b : byteArray) {//16次
            // 取出每一个byte类型，进行转换
            String hex = byteToHexString(b);
            // 将转换后的值放入StringBuffer中
            sb.append(hex);
        }
        return sb.toString();
    }

    /**
     * 将byte转在16进制字符串
     */
    private static String byteToHexString(byte b) { // -31转成e1，10转成0a，。。。
        //将byte类型赋给int类型
        int n = b;
        //如果n是负数
        if (n < 0) {
            //转正数
            //-31的16进制数，等价于求225的16进制数
            n = 256 + n;
        }
        //商(14)，数组的下标
        int d1 = n / 16;
        //余(1)，数组的下标
        int d2 = n % 16;
        //通过下标取值
        return hex[d1] + hex[d2];
    }

    private static String[] hex = {"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};

    /**
     * 测试
     */
    public static void main(String[] args) throws Exception {
        String password = "123456";
        String passwordMD5 = Md5Util.encodeByMd5(password);
        System.out.println(password);
        System.out.println(passwordMD5);
    }
}
